import { defineStore } from 'pinia';
import { store } from '@/store';
import { ACCESS_TOKEN, CURRENT_USER, IS_LOCKSCREEN } from '@/store/mutation-types';
import { has } from 'lodash-es'
import { storage } from '@/utils/Storage';
export interface IUserState {
  token: string;
  username: string;
  welcome: string;
  avatar: string;
  permissions: any[];
  info: any;
}

export const useUserStore = defineStore({
  id: 'app-user',
  state: (): IUserState => ({
    token: storage.get(ACCESS_TOKEN, ''),
    username: '',
    welcome: '',
    avatar: '',
    permissions: [],
    info: storage.get(CURRENT_USER, {}),
  }),
  getters: {
    getToken(): string {
      return this.token;
    },
    getAvatar(): string {
      return has(this.info, 'avatar') ? this.info.avatar : '';
    },
    getNickname(): string {
      return this.username;
    },
    getPermissions(): [any][] {
      return this.permissions;
    },
    getUserInfo(): object {
      return this.info;
    },
  },
  actions: {
    setToken(token: string) {
      this.token = token;
    },
    setAvatar(avatar: string) {
      this.avatar = avatar;
    },
    setPermissions(permissions) {
      this.permissions = permissions;
    },
    setUserInfo(info) {
      this.info = info;
    },
    // 登录
    async login(userInfo) {
      const ex = 7 * 24 * 60 * 60 * 1000;
      storage.set(ACCESS_TOKEN, userInfo.token, ex);
      storage.set(CURRENT_USER, userInfo, ex);
      storage.set(IS_LOCKSCREEN, false);
      this.setToken(userInfo.token);
      this.setUserInfo(userInfo);
      // try {
      //   const response = await login(userInfo);
      //   const { result, code } = response;
      //   if (code === ResultEnum.SUCCESS) {
      //     const ex = 7 * 24 * 60 * 60 * 1000;
      //     storage.set(ACCESS_TOKEN, result.token, ex);
      //     storage.set(CURRENT_USER, result, ex);
      //     storage.set(IS_LOCKSCREEN, false);
      //     this.setToken(result.token);
      //     this.setUserInfo(result);
      //   }
      //   return Promise.resolve(response);
      // } catch (e) {
      //   return Promise.reject(e);
      // }
    },

    // 获取用户信息
    GetInfo() {
      return this.info
      // const that = this;
      // return new Promise((resolve, reject) => {
      //   getUserInfo()
      //     .then((res) => {
      //       const result = res;
      //       if (result.permissions && result.permissions.length) {
      //         const permissionsList = result.permissions;
      //         that.setPermissions(permissionsList);
      //         that.setUserInfo(result);
      //       } else {
      //         reject(new Error('getInfo: permissionsList must be a non-null array !'));
      //       }
      //       that.setAvatar(result.avatar);
      //       resolve(res);
      //     })
      //     .catch((error) => {
      //       reject(error);
      //     });
      // });
    },

    // 登出
    async logout() {
      this.setPermissions([]);
      this.setUserInfo('');
      storage.remove(ACCESS_TOKEN);
      storage.remove(CURRENT_USER);
      return Promise.resolve('');
    },
  },
});

// Need to be used outside the setup
export function useUserStoreWidthOut() {
  return useUserStore(store);
}
